## PATENT ABSTRACTS OF JAPAN

(11)Publication number:

09-212335

(43) Date of publication of application: 15.08.1997

(51)Int.Cl.

G06F 5/06 B41J 29/38

(21)Application number: 08-016726

040700

(71)Applicant: CANON INC

(22)Date of filing:

01.02.1996

(72)Inventor: OKUTSU TOSHIHISA

### (54) ELECTRONIC EQUIPMENT AND ITS CONTROLLING METHOD

### (57)Abstract:

PROBLEM TO BE SOLVED: To shorten the time required for continuously stopping data transfer, to reduce the frequency of time—out of an external equipment and to efficiently execute data transfer processing.

SOLUTION: A timing table 106 stores a high speed receiving timing set 1 and a low speed receiving timing set 2. When the number of idle blocks in a receiving buffer 103 is large, a timing table painter 107 specifies the timing set 1, and when the number is small, specifies the timing set 2. An interface controller 101 receives data from a host computer by the use of the timing set specified by the pointer 107 out of both the timing sets 1, 2. Thereby the buffer 103 can be prevented from being filled with data for a long time and the time-out of the host computer can be reduced.



(19)日本国特許庁(JP)

## (12) 公開特許公報(A)

(11)特許出願公開番号

# 特開平9-212335

(43)公開日 平成9年(1997)8月15日

| (51) Int.Cl. 8 |       | 識別記号 | 厅内整理番号 | FI   |       |     | 技術表示簡所 |
|----------------|-------|------|--------|------|-------|-----|--------|
| G06F           | 5/06  | 311  |        | G06F | 5/06  | 311 |        |
| B41J           | 29/38 |      |        | B41J | 29/38 | Z   |        |

## 審査請求 未請求 請求項の数15 OL (全 15 頁)

| (21)出魔番号 | 特膜平8—16726     | (71)出願人 000001007              |   |
|----------|----------------|--------------------------------|---|
|          |                | キャノン株式会社                       |   |
| (22) 出題日 | 平成8年(1996)2月1日 | 東京都大田区下丸子3丁目30番2号              |   |
|          |                | (72) 発明者 奥津 俊久                 |   |
|          |                | 東京都大田区下丸子3丁目30番2号 キ<br>ノン株式会社内 | 4 |
|          |                | (74)代理人 弁理士 大塚 廉徳 (外1名)        |   |
|          |                |                                |   |

#### (54) 【発明の名称】 電子機器及びその制御方法

### (57) 【要約】

【課題】データ転送を連続して停止する時間を短縮し、 外部機器のタイムアウトの頻度を軽減し、データの転送 処理を効率化する。

【解決手段】タイミング・テーブル106は、高速受信用のタイミングセット1と低速受信用のタイミングセット1と低速受信用のタイミング・デーブル・ポインタ107は、受信パッファ103の空きブロック数が多い場合はタイミングセット1を指定し、少ない場合はタイミングセット1を指定する。インターフェース・コントローラ101は、タイミング・テーブル106に保持されたタイミングセット1または2のうちタイミング・テーブル・ポインタ107によって指定されたタイミングセットを用いてホストコンピュータよりデータを受信する。したがって、受信バッファ103が長時間満杯になることを防止し、ホストコンピュータのタイムアウトを低減することができる。



(2)

特開平9-212335

### 【特許請求の範囲】

【請求項1】 外部機器よりデータを取得し該データに 基づいて処理を行う電子機器であって、

前記外部機器よりデータを受信する受信手段と、

受信したデータを一時的に保持する受信バッファと、 前記受信パッファの空き容量に応じて前記外部機器から のデータの転送頻度を調整すべく、前記外部機器による データの転送を許可するタイミングを調整する調整手段 Ł,

を備えることを特徴とする電子機器。

【請求項2】 前記調整手段は、前記受信バッファの空 き容量が少ない場合に前記外部機器からのデータの転送 頻度を低くするように前記タイミングを調整することを 特徴とする請求項1に記載の電子機器。

【請求項3】 前記受信パッファは、通常受信領域と予 備受信領域とを有し、前記調整手段は、前記通常受信領 域に空き領域が存在する場合には、前記外部機器からの データの転送頻度を高くするように前記タイミングを調 整し、前記通常受信領域に空き領域が存在せず、前記予 備受信領域を使用する場合には、前記外部機器からのデ 20 ータの転送頻度を低くするように前配タイミングを調整 することを特徴とする請求項1に記載の電子機器。

【請求項4】 前記調整手段は、前記タイミングを規定 する少なくとも2組のタイミング情報を有し、該少なく とも2組のタイミング情報のいずれかを選択して前記外 部機器によるデータの転送を許可するタイミングを取得 することを特徴とする請求項1万至請求項3のいずれか 1項に記載の電子機器。

【請求項5】 前記タイミング情報は雷換え可能である ことを特徴とする請求項4に記載の電子機器。

【請求項6】 前記タイミング情報は前記外部機器より 書換え可能であることを特徴とする請求項5に記載の電

【請求項7】 前記受信手段は、前記外部機器より印刷 データを含むデータを受信し、

前記印刷データを解析する解析手段と、

前記印刷データの解析結果に基づいて画像を形成する画 像形成手段と、

をさらに備えることを特徴とする請求項1乃至請求項6 のいずれか1項に記載の電子機器。

【請求項8】 外部機器よりデータを取得し該データに 基づいて処理を行う電子機器の制御方法であって、

前記外部機器よりデータを受信する受信工程と、

受信したデータを受信パッファに転送する転送工程と、 前記受信パッファの空き容量に応じて前記外部機器から のデータの転送頻度を調整すべく、前記外部機器による データの転送を許可するタイミングを調整する調整工程 뇬.

を備えることを特徴とする電子機器の制御方法。

【請求項9】 前記調整工程は、前記受信バッファの空 50 【0002】

き容量が少ない場合に前記外部機器からのデータの転送 頻度を低くするように前記タイミングを調整することを 特徴とする請求項8に記載の電子機器の制御方法。

【諸求項10】 前記受信バッファは、通常受信領域と 予備受信領域とを有し、前記調整工程は、前記通常受信 領域に空き領域が存在する場合には、前記外部機器から のデータの転送頻度を高くするように前記タイミングを 調整し、前記通常受信領域に空き領域が存在せず、前記 予備受信領域を使用する場合には、前記外部機器からの 10 データの転送頻度を低くするように前記タイミングを調 整することを特徴とする請求項8に記載の電子機器の制 御方法。

【請求項11】 前記調整工程は、前記タイミングを規 定する少なくとも2組のタイミング情報のいずれかを選 択して前記外部機器によるデータの転送を許可するタイ ミングを取得することを特徴とする請求項8乃至請求項 10のいずれか1項に記載の電子機器の制御方法。

【請求項12】 前記タイミング情報を書換える書換え 工程をさらに備えることを特徴とする請求項11に記載 の電子機器の制御方法。

【請求項13】 前記書換え工程は、前記外部機器から のコマンドに基づいて前記タイミング情報を書換えるこ とを特徴とする請求項12に記載の電子機器の制御方

【請求項14】 前記受信工程は、前記外部機器より印 刷データを含むデータを受信し、

前記印刷データを解析する解析工程と、

前記印刷データの解析結果に基づいて画像を形成する画 像形成工程と、

30 をさらに備えることを特徴とする請求項8乃至請求項1 3のいずれか1項に記載の電子機器の制御方法。

【諸求項15】 外部機器よりデータを取得し眩データ に基づいて処理を行う電子機器を制御するプログラムを 収めたコンピュータ可読メモリであって、

前記外部機器よりデータを受信する受信工程のコード

受信したデータを受信パッファに転送する転送工程のコ - 44.

前記受信パッファの空き容量に応じて前記外部機器から 40 のデータの転送頻度を調整すべく、前記外部機器による データの転送を許可するタイミングを調整する調整工程 のコードと、

を備えることを特徴とするコンピュータ可読メモリ。 【発明の詳細な説明】

[0001]

[発明の属する技術分野] 本発明は、電子機器及びその 制御方法に係り、特に外部機器よりデータを取得し該デ 一夕に基づいて処理を行う電子機器及びその制御方法に 関する。

(3)

特開平9-212335

3

【従来の技術】ブリンタとホストコンピュータを接続し、印刷データを転送するインターフェースの1つとして、セントロニクス・インターフェースがある。従来は、セントロニクス・インターフェースを用いたシステムにおいては、印刷データの処理能力がセントロニクス・インターフェースによるデータ転送能力よりも優れていたため、従来よりデータ転送速度の向上が望まれていた。近年、この要望に対して、ホストコンピュータ側、ブリンタ側のインターフェースに関する処理をハードウエア化したり、装置内部のデータ転送にDMA(Direct 10 Memory Access)を採用することなどにより、ホストコンピュータとブリンタ間で高速にデータ転送を行うことが可能になった。

#### [0003]

【発明が解決しようとする課題】しかしながら、ホストコンピュータよりプリンタに転送するデータは、従来はテキストデータが主体であり、転送データの規模が比較的小さかったが、現在においては、ピットマップ画像等を含むグラフィックデータを主体とする場合が多くなり、転送データが大規模化する傾向にある。

【0004】したがって、データ転送速度は高速化されたものの、転送データも大規模化したため、プリンタの受信バッファが満杯になる時間が長くなった。DMAコントローラは、インターフェースにおいて受信したデータをプロック単位で受信バッファに転送するため、受信バッファに1ブロック以上の空き領域が生じるまで、ホストコンピュータからのデータの受信を停止する必要がある。ところが、複雑な印刷データは、コマンド解析時間を長大にし、それに伴い受信バッファに空き領域を確保するまでの時間も長大になる。

[0005] これに対し、ホストコンピュータの中には、所定の時間を超過してデータの送信を停止されると、プリンタは正常に動作しているにも拘わらず、ハングアップしたものとと看做して処理を中止するものがある。

【0006】上記の問題は、プリンタとホストコンピュータとの間のデータ転送に限られるものではなく、所定の時間を経過しても応答がない場合に異常が発生したとみなして処理を中止する外部機器に接続して用いる電子機器一般に共通する問題であり、そのインターフェース 40手段もセントロニクス・インターフェースに限られるものではない。

【0007】本発明は、上記問題点に鑑みてなされたものであり、データ転送を連続して停止する時間を短縮し、外部機器が所定の時間を経過しても応答がない場合に異常が発生したとみなして処理を中止する頻度を軽減し、データの転送処理を効率化することを目的とする。【0008】

【課題を解決するための手段】上記課題を解決するた 記通常受信領域に空き領域が存在する場合には、前記外め、本発射に係る電子機器は、外部機器よりデータを取 50 部機器からのデータの転送頻度を高くするように前記タ

得し該データに基づいて処理を行う電子機器であって、 前記外部機器よりデータを受信する受信手段と、受信し たデータを一時的に保持する受信パッファと、前記受信 パッファの空き容量に応じて前記外部機器からのデータ の転送頻度を調整すべく、前記外部機器によるデータの 転送を許可するタイミングを調整する調整手段とを備え ることを特徴とする。

[0009] 本発明の好適な実施の態様に拠れば、例えば、前記調整手段は、前記受信パッファの空き容量が少ない場合に前記外部機器からのデータの転送頻度を低くするように前記タイミングを調整する。

【0010】 また、例えば、前記受信パッファは、通常 受信領域と予備受信領域とを有し、前記調整手段は、前 記通常受信領域に空き領域が存在する場合には、前記外 部機器からのデータの転送頻度を高くするように前記タ イミングを調整し、前記通常受信領域に空き領域が存在 せず、前記予備受信領域を使用する場合には、前記外部 機器からのデータの転送頻度を低くするように前記タイ ミングを調整する。

0 【0011】また、例えば、前記調整手段は、前記タイ ミングを規定する少なくとも2組のタイミング情報を有 し、該少なくとも2組のタイミング情報のいずれかを選 択して前記外部機器によるデータの転送を許可するタイ ミングを取得する。

【0012】また、例えば、前記タイミング情報は各換え可能である。

【0013】また、例えば、前記タイミング情報は前記 外部機器より審換え可能である。

【0014】また、例えば、前記受信手段は、前記外部 機器より印刷データを含むデータを受信し、前記印刷デ ータを解析する解析手段と、前記印刷データの解析結果 に基づいて画像を形成する画像形成手段とをさらに備え る。

【0015】また、本発明に係る電子機器の制御方法は、外部機器よりデータを取得し該データに基づいて処理を行う電子機器の制御方法であって、前記外部機器よりデータを受信する受信工程と、受信したデータを受信パッファに転送する転送工程と、前記受信パッファの空き容量に応じて前記外部機器からのデータの転送を許可するタイミングを調整する調整工程とを備えることを特徴とする。

【0016】本発明の好適な実施の態様に拠れば、例えば、前記調整工程は、前記受信バッファの空き容量が少ない場合に前記外部機器からのデータの転送頻度を低くするように前記タイミングを調整する。

【0017】また、例えば、前記受信バッファは、通常 受信領域と予備受信領域とを有し、前記調整工程は、前 記通常受信領域に空き領域が存在する場合には、前記外 部機器からのデータの転送頻度を高くするように前記タ (4)

特開平9-212335

イミングを調整し、前記通常受信領域に空き領域が存在 せず、前記予備受信領域を使用する場合には、前記外部 機器からのデータの転送頻度を低くするように前記タイ ミングを調整する。

【0018】また、例えば、前記調整工程は、前記タイ ミングを規定する少なくとも2組のタイミング情報のい ずれかを選択して前記外部機器によるデータの転送を許 可するタイミングを取得する。

【0019】また、例えば、前記タイミング情報を審換 える書換え工程をさらに備える。

【0020】また、例えば、前記書換え工程は、前記外 部機器からのコマンドに基づいて前記タイミング情報を

【0021】また、例えば、前記受信工程は、前記外部 機器より印刷データを含むデータを受信し、前記印刷デ 一タを解析する解析工程と、前記印刷データの解析結果 に基づいて画像を形成する画像形成工程とをさらに備え

【0022】また、本発明に係るコンピュータ可読メモ リは、外部機器よりデータを取得し該データに基づいて 20 処理を行う電子機器を制御するプログラムを収めたコン ピュータ可読メモリであって、前記外部機器よりデータ を受信する受信工程のコードと、受信したデータを受信 バッファに転送する転送工程のコードと、前記受信パッ ファの空き容量に応じて前記外部機器からのデータの転 送頻度を調整すべく、前記外部機器によるデータの転送 を許可するタイミングを調整する調整工程のコードとを 備える。

[0023]

【発明の実施の形態】以下、図面を参照しながら本発明 30 の好適な実施の形態の一例を説明する。

【0024】図1は、本実施の形態に係る画像形成装置 の構成例を示すプロック図である。100は画像形成装 置本体であり、セントロニクス・インターフェース・ケ ープル120を介してホストコンピュータ(不図示)と 接続されている。

【0025】画像形成装置100内の各ブロックは、内 部バス112によって制御部110に接続されている。 制御部110は、制御プログラムの格納領域やワーク領 域等を有するメモリ110a及びその制御プログラムを 40 読み込んで各プロックを制御するCPU110bを有す る。なお、制御プログラムの詳細は後述する。

【0026】101は、セントロニクス・インターフェ ース・ケーブル120を通じてホストコンピュータとの 間で信号をやり取りするセントロニクス・インターフェ ース・コントローラである。102は、セントロニクス ・インターフェース・コントローラ101から受信パッ ファ103へ受信データをDMA転送するDMAコント ローラである。103は、転送された受信データを保持

3を管理する管理情報を保持する受信バッファ管理レジ スタ群である。105は、ユーザの指示を入力したり、 画像形成装置100の状態を表示したりする操作パネル である。

【0027】106は、セントロニクス・インターフェ ース・コントローラ101のインターフェース信号に関 する制御タイミング情報を格納したタイミング・テーブ ルである。107は、タイミングテーブル106内の複 数のタイミング情報のいずれかを受信バッファ103の 状態に応じて指定するタイミング・テーブル・ポインタ である。108は、ホストコンピュータより受信した印 刷データやコマンドを解析するコマンド解析部である。 109は、印刷データをビットマップ画像に展開する展 開メモリである。111は、記録紙等に永久可視画像形 成するプリンタエンジンである。

【0028】図2は、受信パッファ管理レジスタ群の標 成例を模式的に示す図である。受信バッファ管理レジス タ雑104は、6つのレジスタを有する。

【0029】空きプロック数レジスタ(FREEBL K) 201は、受信バッファ103の空きブロック数を 保持するレジスタである。カレント受信ブロックレジス タ(RCURBLK)202は、受信ポインタが指示す るプロック番号を保持するレジスタである。カレント解 析プロックレジスタ(ACURBLK)203は、解析 ポインタが指示するブロック番号を保持するレジスタで ある。以上の3つのレジスタ201~203は、初期化 処理において適切な値に設定される。

【0030】総ブロック数レジスタ(TOTALBL K) 204は、受信パッファ103の総プロック数を保 持するレジスタである。予備ブロック数レジスタ(SU BBLK) 205は、受信パッファ103の予備ブロッ ク数を保持するレジスタである。プロックサイズレジス 夕(BLKSIZE)206は、1ブロックのサイズを 保持するレジスタである(受信バッファ103は、複数 のブロックを有する)。以上3つのレジスタ204~2 0.6は、予め初期値が設定され、操作パネル105また はホストコンピュータを介して設定を変更可能な構成と

【0031】図3は、ホストコンピュータと画像形成装 置の間をセントロニクス・インターフェースを用いてデ 一タ転送する一般的なタイミングを示す図である。な お、同図は1パイトのデータ転送を示している。DAT A信号は、ホストコンピュータが画像形成装置に転送す るデータであり、8ビットのバスで構成される。 nST ROBE信号は、ホストコンピュータが出力する信号で あり、信号レベルがLo("O")の時に画像形成装置 100に対してデータを出力したことを示す。 画像形成 装置100は、nSTROBE信号の立ち下がりでDA TA信号上のデータを受信データとして取り込む。BU する受信バッファである。104は、受信パッファ10 50 SY信号は、画像形成装置が出力する信号であり、信号 (5)

レベルがHi (" 1") の時は、次のデータを受け付けることができないことを示す。nACK信号は、画像形成装置 100が出力する信号であり、信号レベルがLoの時に、データを受信したことを示す。

【0032】時刻 t 1で、ホストコンピュータは、画像 形成装置100に転送すべきデータをDATA信号上に出力する。次いで、時刻 t 2で、ホストコンピュータ は、nSTROBE信号の信号レベルをHiからLaにする。このタイミングで、画像形成装置100は、DATA信号上のデータを取り込む。また、画像形成装置1 100は、時刻 t 2で、セントロニクス・インターフェース・コントローラのシーケンサを起動し、BUSY信号 及びnACK信号の制御を開始する。

[0033] 時刻t3で、画像形成装置100は、BU SY信号の出力レベルをLoからHiにする。そして、 時刻 t 4 で、ホストコンピュータは、n STROBE信 号の信号レベルをLoからHiにする。時刻t5で、画 像形成装置100は、nACK信号の信号レベルをHi からしっにし、データを受信したことをホストコンピュ ータに通知する。ここで、時刻 t 2~ t 5 の時間をAC 20 KFとする。時刻t6で、画像形成装置100は、nA CK信号の信号レベルをLoからHiにする。ここで、 時刻 t 2~ t 6 の時間をACKRとする。時刻 t 7 で、 画像形成装置100は、BUSY信号の信号レベルを以 iからLoにする。ここで、時刻t2~t7の時間をB USYFとする。以上の動作により、8ピット(1バイ ト)のデータ転送を終了する。BUSY信号及びnAC K信号は、セントロニクス・インターフェース・コント ローラ101によって制御される。なお、nACK信号 をHi→Lo→HiにすることをnACKパルスの出力 30 と呼ぶことにする。

【0034】制御部110がDMAコントローラ102を起動し、受信データを受信パッファ103に転送することにより、セントロコクス・インターフェース・コントローラ101は、タイミングテーブル106内のタイミング情報に基づいてnACKパルスを出力し、BUSY信号をLoにする。これにより、セントロニクス・インターフェース・コントローラ101は、受信可能状態であることをポストコンピュータに通知する。

【0035】セントロニクス・インターフェース・コン 40トローラ101に関するタイミング情報(ACKF, ACKR, BUSYF)は、例えば、操作パネル105を介して制御部110によって様々な値に設定することが可能である。したがって、画像形成装置100は、1パイトのデータの転送速度を自由にに設定することが可能である。

【0036】図4は、タイミング・テーブルの構成例を 模式的に示す図である。図示の例は、2組のタイミング 情報を備えるものである。

[0037] {BUSYF1, ACKF1, ACKR

1)のタイミング情報(タイミングセット1)は、タイミング・テーブル・ポインタ107が示す値が1の時に選択される。また、【BUSYF2、ACKF2、ACKR2】のタイミング情報(タイミングセット2)は、タイミングテーブルポインタ107が示す値が2の時に選択される。本実施の形態においては、データ転送速度は、タイミングセット1が高速であり、タイミングセット2が低速であり、これらのタイミング情報は、予め設定されているものとする。

【0038】図5は、受信バッファ103の構成例を模式的に示す図である。図示の例は、"TOTALBLK=n"とした場合に、受信バッファ103がn個のブロックから構成されることを模式的に示している。この受信バッファ103は、リングパッファ構成とした一例を示しており、ブロック1から順にブロックnまで受信/解析ポインタが移動し、ブロックnの次はブロック1に該ポインタが移動する。

【0039】本実施の形態においては、受信データは、 DMAコントローラ102によりセントロニクス・イン ターフェース・コントローラ101から受信パッファ1 03にブロック単位でDMA転送される。

【0040】各ブロックは、DMAコントローラ102による1ブロックの転送量(例えば、8bit×2048ワード(2048byte))のメモリ領域で構成される。なお、1ブロックの容量は、DMAコントローラ102の設定或いは構成により、任意に定めることができ、上記の例に限定されるものではない。

【0041】受信ポインタは、DMAコントローラ102によって管理される。すなわち、DMAコントローラ102は、DMA転送の対象となるアドレス情報を保持しており、これに基づいて該当するアドレスを出力する。なお、DMAコントローラ102の初期化は、制御部110によって行うことができる。

【0042】解析ポインタは、コマンド解析部108が 指示するアドレスであり、解析すべき受信データが保持 されたアドレスが指示される。図示の例は、"受信ポイ ンタ=0"、"解析ポインタ=0"の状態、すなわち、 初期化直後或いは受情パッファが空の状態を示す。ま た、いずれのポインタもその値が"0"の時に、受信バ ッファの先頭、すなわちブロック1の先頭のアドレスを 指示する。

【0043】図6は、一般的な構成の受信バッファ内に 受信データが存在する状態を模式的に示す図である。図 示の例においては、受信ポインタがブロック3の先頭 (BLKSIZE×2)を、解析ポインタがブロック3 内のアドレス(BLKSIZE×2+a,0<a>とa<BL KSIZE)を指示している。この場合、コマンド解析 部108が未解析の受信データは、解析ポインタが指示 するアドレスから受信パッファの終端までと、受信パッ ファの先頭から受信ポインタまでの領域に存在する。

特開平9-212335

10

【0044】この状態で、DMAコントローラ102が次に受信データを転送する先はブロック3である。ところが、解析ポインタは、ブロック3内のアドレスを指示しているため、解析ポインタがプロック4の先頭アドレスを指示するまで、セントロニクス・インターフェース・コントローラ101は、ホストコンピュータに対してデータの受信を停止する旨の指示を出す(nBUSY=Hi)。この時、空ブロックはなく、空ブロック数レジスタ(FREEBLK)の値は"0"となっている。

【0045】データの受信を停止した状態が一定時間を 10 越えると、ホストコンピュータは、画像形成装置からの 応答がないものと判断し、タイムアウト処理を行う場合 がある。タイムアウト処理では、ホストコンピュータは、画像形成装置に対するデータ転送処理を中止するため、データ転送処理を続行する場合には、オペレータは、ホストコンピュータにデータ転送を再開するよう指示する必要があり、画像の形成処理が非効率的になるという問題がある。しかし、受信データの解析に長時間を要する場合には、受信パッファが未解析の受信データで満たされた状態が長時間に及ぶことになり、ホストコン 20 ピュータによるタイムアウト処理の頻度も高くなる。

【QQ46】図7は、受信バッファが満たされ、画像形 成装置がホストコンピュータにデータの受信停止を通知 する様子を模式的に示す図である。空きブロックが1つ の状態で、DMAコントローラ102が1プロック分の 受信データを転送 (時刻 t 1 1) すると、空きプロック が存在しなくなり、セントロニクス・インターフェース ・コントローラ101は、BUSY信号の信号レベルを Hiの状態に保持し、ホストコンピュータからのデータ・ の送信を停止させる。そして、受信データの解析・処理 30 を行ない、1プロックの空きが確保されたら、BUSY 信号をLoにし、nACKパルス出力を行ない、ホスト コンピュータにデータ受信が可能である旨を知らせる (時刻 t 1 2)。これを受けて、ホストコンピュータ は、データの転送を開始する(時刻 t 1 3)。時刻 t 1 1~t12間の時間が一定の時間(タイムアウト時間) を越えると、ホストコンピュータは、タイムアウト処理 によりデータ転送を中止する。

【0047】したがって、タイミングテーブル101内 10のタイミング情報は、ホストコンピュータがタイムアウ 40 る。ト処理を行う前に、すなわちタイムアウト時間内にホストコンピュータに対してデータの転送を許可するようなタイミングを規定するものである必要がある。なお、タイミング情報は、予め初期値が設定されているものとする。また、この設定は、操作パネル105により変更可能な構成とすることが望ましい。接続するホストコンピュータの仕様に適合可能にするためである。 ップ

【0048】図8は、セントロニクス・インターフェー の転送速度を低速にし、データの受信量を調整すること スのデータ転送速度の切替処理を模式的に示す図であ により、データの転送を完全に停止することを避け、ホ る。セントロニクス・インターフェース・コントローラ 50 ストコンピュータのタイムアウト処理を防止することが

101に関するタイミング情報(タイミングセット1または2)は、DMAコントローラ102による1ブロックの転送が終了する都度受信パッファ103の状態に応じて変更する。

【0049】同図においては、時刻 t 21 までは、タイ ミングセット1 (タイミングテープルポインタ=1) に 基づいて高速で転送が行われている。その後、制御部1 10は、受信パッファ103の通常受信領域(後述)の 空きブロックの有無を判断し、空きプロックが存在しな かったら、タイミング・テーブル・ポインタ107の値 を"2"(すなわち、低速)に設定する。設定を完了し たら、BUSY信号をLoにし、nACKパルス出力を 行ない、ホストコンピュータにデータの受信が可能であ る旨を知らせる(時刻 t 2 2)。これに対し、ホストコ ンピュータは、次のデータの転送を開始する(時刻 t 2 3)。以降、セントロニクス・インターフェース・コン トローラ102は、受信パッファ103の通常受信領域 に空きブロックができるまで、タイミングセット2に基 づいて動作することになり、低速でデータが転送され る。ここで、データの転送速度が高速であるとは、デー 夕の転送頻度が高いことを意味し、一方、データの転送 速度が低速であるとは、データの転送頻度が低いことを 意味する。

【0050】図9は、本実施の形態における受信バッファの構成例を模式的に示す図である。受信パッファ103は、全体でヵ個のブロック(TOTALBLK=n)を有し、このヵ個のブロックは、(n-m)個のブロックを有する通常受信領域901と、m個のブロックを有する予備受信領域902に区分されている。

【0051】セントロニクス・インターフェース・コントローラ101は、通常受信領域901に空きブロックが存在する場合には、タイミングセット1(高速)に基づいてデータを受信する。この時、DMAコントローラ102は、受信データを通常受信領域901に転送する。また、通常受信領域901に空きブロックが存在しない場合には、セントロニクス・インターフェース・コントローラ101は、タイミングセット2(低速)に基づいてデータを受信する。この時、DMAコントローラ102は、受信データを予備受信領域902に転送する

【0052】換雪すると、通常受信領域901が受信データで満たされると、すなわち受信バッファ103の空き領域が少なくなると、セントロニクス・インターフェース・コントローラ101は、受信速度を低速に切り替えて受信し、DMAコントローラ102は、予備受信領域902に受信データを転送する。このように、受信バッファ103の空き領域が少なくなった場合に、データの転送速度を低速にし、データの受信量を調整することにより、データの転送を完全に停止することを避け、ホストコンピュータのタイムアウト処理を防止することが

(7)

11

できる。なお、、予備受信領域902が不足しない限り、すなわち、タイミングセット2に従ってデータを受信できる限り、解析に長時間を要するデータを受信する場合においてもホストコンピュータのタイムアウト処理は発生しない。

【0053】図10は、画像形成装置におけるデータ解析量の時間変化の一例を模式的に示す図である。データ解析量は、単位時間に画像形成装置が解析したデータ量である。図示の例は、以下の条件によるものである。

【0054】1プロックサイズ:2Kbyte 総プロック数 (TOTALBLK):4block 予備プロック数 (SUBBLK):2block 図11は、従来例におけるデータ転送量の時間変化

- (a) と、空きプロック数の時間変化(b) を示す図である。また、図12は、本実施の形態におけるデータ転送量の時間変化(a)と、空きプロック数の時間変化
- (b) を示す図である。ここで、データ転送量は、単位 時間に画像形成装置100が受信したデータ量である。 これらは、図10に示すデータ解析量の下でのデータ転 送量と空きプロック数とを示している。

【0055】図11(a)に示す如く、従来は、受信バッファが満たされるまで高速に受信を行うため、受信バッファが一杯になった時点でデータ転送が停止し、受信バッファに空きプロックが生じるまでの期間Twaにおいては、データの転送がなされない。したがって、この期間Twaがホストコンピュータのタイムアウト時間を超過すると、ホストコンピュータは、タイムアウト処理によりデータ転送を中止する。

【0056】一方、図12(a)に示す如く、本実施の形態においては、通常受信領域901が満たされるまでは高速に受信を行ない、その後は、受信速度を低速に切り替えて、予備受信領域902を用いて受信を行う。なお、図示の例は、予備受信領域902を用いる場合には、通常受信領域901を用いる場合のデータ受信速度の1/4の速度で受信を行ったものである。

【0057】この場合、予備受信領域902が一杯にならず、画像形成装置100は、受信停止状態にならないため、ホストコンピュータは、タイムアウトすることなくデータを転送することができる。

【0058】図13は、側御部110のメモリ110aに格納された制御プログラムによる処理の流れを示す図である。制御部110のCPU110bは、メモリ110aに格納された不図示のオペレーティング・システム(OS)に基づいて制御プログラムに係る複数のタスクを管理することにより、データ受信、データ解析、展開メモリ109に対する画像措面、プリンタエンジン111による印刷処理等を制御する。したがつて、以下に示すデータ受信タスク、コマンド解析タスク、その他のタスクはOSの管理の下、時分割により各タスクが独立して並列処理されるものとする。

【0059】ステップS1301では、受信ポインタ及び解析ポインタを"0"に初期化する。"0"は、受信バッファ103の先頭のアドレスを示す。ステップS1302では、受信ポインタが指示するカレント受信ブロ

302では、受信ポインタが指示するカレント受信ブロック(RCURBLK)を"1"に、解析ポインタが指示するカレント解析プロック(ACURBLK)を"1"に各々設定する。"RCURBLK=1"及び"ACURBLK=1"は、受信ポインタと解析ポインタが

共に受信パッファ 1 0 3 の先頭プロックを指示すること 10 を意味する。

【0060】ステップS1303では、受信バッファ管理レジスタ群14の総ブロック数レジスタ(TOTAL BLK)204の値を空きブロック数レジスタ(FRE EBLK)201に設定する。なお、その他のレジスタである、総ブロック数レジスタ(TOTALBLK)204、予備プロックレジスタ(SUBBLK)205、ブロックサイズレジスタ(BLKS12E)206は、立上時等に予め設定され、操作パネル15等により変更可能に構成されている。

20 【0061】ステップS1304では、タイミング・テーブル・ポインタ107の値として"1"を設定する。"タイミング・テーブル・ポインタ=1"は、タイミングテーブル106内の先頭のタイミング情報(タイミングセット1)を指定し、本実施の形態においては、高速のタイミングセット1が指定される。

【0062】ステップS1305では、タイミング・テープル・ポインタ107が指定するタイミング・テープル16のタイミング情報をセントロニクス・インターフェース・コントローラ101に設定する。この時、"タイミング・テーブル・ポインタ=1"であるので、(BUSYF1、ACKF1、ACKR1)なるタイミング情報、すなわちタイミングセット1が設定される。

【0063】ステップS1306では、データ受信タスクを起動する。なお、データ受信タスクの詳細は後述する。ステップS1307では、コマンド解析タスクを起動する。なお、コマンド解析タスクの詳細は後述する。ステップS1308では、その他のタスク(例えば、展開メモリ109への画像描画タスク、プリンタエンジン111の制御タスク、操作パネル105の制御タスク、その他)を起動する。

【0064】図14は、ステップS1306において起動されるデータ受信タスクにおける処理例を示すフローチャートである。デーク受信タスクは、1)通常受信領域901に空きブロックが存在する場合には、タイミング・テーブル・ポインタを"1"にし、受信速度を高速にしてデーク受信を行ない、2)通常受信領域901に空きブロックが存在する場合には、タイミング・テーブル・ポインタを"2"にし、受信速度を低速にしてデーク受信を行ない、3)通常受信領域901及び

(8)

特開平9-212335

14

予備受信領域 9 0 2 の双方に空きブロックが存在しない 場合には、データ受信を停止するように動作する。

【0065】 先ず、ステップS1401では、タイミング・テーブル・ポインタ107が指定するタイミング・テーブル106内のタイミング情報(タイミングセット1または2)をセントロニクス・インターフェース・コントローラ101に設定する。ステップS1402では、空きブロック数レジスタ(FRBEBLK)の値を1減じ、ステップS1402では、1プロック分のデータを受信する1ブロック受信処理(詳細は後述)を実行10する。

【0066】ステップS1404では、空きブロック数レジスタ(FREEBLK)の値を読込み、ステップS1405において、FREEBLKの値が予備ブロック数レジスタ(SUBBLK)の値より大きいか否かを判定する。判定の結果、FREEBLKの値がSUBBLKの値よりも大きい場合は、通常受信領域901に空きブロックが存在するため、ステップS1406に進み、タイミング・テーブル・ポインタ107の値を"1"(高速のタイミングセット1を指定)にしてステップS20

1401に戻る。

【0067】一方、FREEBLKの値がSUBBLKの値よりも大きくない場合は、通常受信領域901に空きブロックが存在しないため、ステップS1407に進み、タイミング・テーブル・ポインタ107の値を"2"にする(低速のタイミングセット2を指定)次いで、ステップS1408では、FREEBLKの値を読込み、ステップS1409において、FREEBLKが0よりも大きいか否か、すなわち、空きプロックが存在する場合とは、ステップS1408及びS1409の処理を繰り返す。

【0068】図15は、ステップ51403の1プロック受信処理の一例を示すフローチャートである。この処理は、前述のように、ホストコンピュータより1ブロック分のデータを受信し、受信バッファ103に格納する処理である。また、この処理は、制御部110がセントロニクス・インターフェース・コントローラ101及びDMAコントローラ102を制御することにより実行す40る。

【0069】先ず、ステップS1501では、セントロニクス・インターフェース・コントローラ101を介してホストコンピュータに受信可能状態であることを通知する。受信可能状態の通知は、例えば、図7に示す時刻 t12における場合のように、BUSY信号をLoにしてnACK信号パルスを出力することにより行う。

【0070】次いで、ステップS1502において、制御部110は、DMAコントローラ102を起動する。 DMAコントローラ102を起動すると、データの受 信、受信バッファ103への受信データの転送は、セントロニクス・インターフェース・コントローラ101と DMAコントローラ102によって制御されるが、便宜上それらの処理も同一のフローチャートにおいて示している。

【0071】ステップS1503では、セントロニクス・インターフェース・コントローラ101は、1バイトのデータを受信する。この受信に関する処理は、セントロニクス・インターフェース・コントローラ101は、図3に示すタイミング図の如く動作する。

【0072】ステップS1504では、セントロニクス・インターフェース・コントローラ101において受信したデータを、DMAコントローラ12により受信ポインタが指示する受信バッファ13上のアドレスに転送する。ステップS1505では、DMAコントローラ102は、受信ポインタの値を1加算する。

【0073】ステップS1506では、受信ポインタの値がカレント受信プロックのアドレス空間(RCURB LK×BLKSIZE)を超えたか否かを判定する。その結果、受信ポインタの値がカレント受信プロックのアドレス空間を超えたと判定した場合、すなわち1プロックの転送を終了した場合には、ステップS1507に進む。ここで、DMAコントローラ102は、1プロック分の転送が終了したため、再度超動されるまで停止状態になる。

【0074】ステップS1507では、セントロニクス・インターフェース・コントローラ101は、ホストコンピュータに受信停止状態を通知する(例えば、図7の時刻 t 11のようにBUSY信号をHiにする)。ステップS1508では、カレント受信プロックの値(RCURBLK)を1増加し、ステップS1509において、カレント受信プロック(RCURBLK)の値とを比較で、カレント受信プロック(RCURBLK)の値とを比較し、RCURBLKの方が大きい場合には、ステップS1510において、RCURBLKを"1"、受信ポインタを"0"とし、これにより受信パッファ103をリングバッファとして使用する。

【0075】図16は、ステップS1307において起動されるコマンド解析タスクにおける処理例を示すフローチャートである。この処理は、受信バッファ103に受信データが存在する場合に、それを読み込んで解析するものである。なお、一連の処理は、制御部110により制御されることは既述の通りである。

【0076】先ず、ステップS1601では、受信ポインタの値をDMAコントローラ102より読込み、ステップS1602では、解析ポインタの値を読み込む。そして、ステップS1603において、双方のポインタの値が毎しいか否かを判定する。双方のポインタの値が一

16

致するときは、受信データが存在しないことを意味し、 双方のポインタの値が一致しない時は、受信データが存 在することを意味する。判定の結果、受信データが存在 しない場合には、ステップS1601に戻り、ステップ 51601及び51602の処理を繰り返す。

15

【0077】一方、受信データが存在する場合には、ス テップS1604において、解析ポインタが指示するデ ータを読み込み、ステップS1605において、その読 み込んだデータをコマンド解析部108に引き渡し、コ マンド解析部108によってコマンドを解析し、ステッ 10 プS1606で解析ポインタを1加算する。

【0078】ステップS1607では、解析ポインタの 値がカレント解析ブロックのアドレス空間(ACURB LK×BLKSIZE) を超えた否かを判定する。その 結果、解析ポインタの値がカレント解析プロックのアド レス空間を超えない場合、すなわち、解析ブロック内の データの解析が完了していないと判定した場合には、ス テップS1601に戻り、解析ポインタの値がカレント 解析プロックのアドレス空間のアドレスを超えた場合 は、ステップ51608に進む。

【0079】ステップ51608では、空きブロック数 レジスタ (FREEBLK) の値を1加算し、ステップ S1609では、カレント解析プロックレジスタ(AC URBLK) を1加算する。

【0080】ステップS1610では、カレント解析プ ロックレジスタ(ACURBLK)の値が総プロック数 レジスタ (TOTALBLK) の値より大きいか否かを 判定し、大きい場合には、ステップS1611におい て、ACURBLKを"l"、解析ポインタを"0"と してステップS1601に戻る。

【0081】以上説明したように、受信パッファの通常 受信領域が満たされた場合、すなわち、受信パッファの 空きプロックが少なくなったときに、データの転送速度 を低速にし、データ転送を連続して停止する時間を短縮 することにより、ホストコンピュータ等のデータの供給 側の機器のタイムアウトを軽減し、もってデータの転送 効率を向上することができる。

【0082】次に、タイミングテーブル106内のタイ ミング情報をホストコンピュータからのコマンドにより 設定する方法の一例について説明する。

【0083】図17は、タイミング設定コマンドの一例 を構式的に示す図である。タイミング設定コマンド17 00は、このコマンドがタイミング設定コマンドである ことを示すコマンド識別子1701、設定(変更)すべ きタイミング情報を特定するタイミング・テーブル・ポ インタ1702、タイミング情報(BUSY, ACK F、ACKR) 1703~1705を含む。このタイミ ング設定コマンド1700は、ホストコンピュータより 受信し、前述のコマンド解析処理(ステップ5160

指示は、操作パネル105から入力可能な構成であって

【0084】図18は、コマンド解析処理(ステップS 1505) において解析されたコマンドがタイミング設 定コマンドである場合に実行されるタイミング設定タス クの一例を示すフローチャートである。なお、このタイ ミング設定タスクの実体は、メモリ110gに格納され たブログラムコードである。

【0085】このタスクが起動されると、先ずステップ S1801において、コマンド解析部108よりコマン ドの解析結果(1702~1705)を取得する。そし て、ステップS1802において、タイミングテーブル 106内のタイミング情報のうち、タイミング・テープ ル・ポインタ1702によって指定されたタイミング情 報を取得した解析結果に基づいて設定する。

【0086】以上のように、タイミングテーブルの内容 を変更可能な構成とすることにより、例えば、接続する ホストコンピュータ等の外部機器の仕機に応じて、或い は取り扱うデータの規模、種類等に応じて最適なタイミ ング情報を設定することが可能になり、各機器の仕様に 適合した効率的なデータ転送を実現することが可能にな る。

【0087】なお、上記の実施の形態は、タイミング情 報として高速用(タイミングセット1)と、低速用(タ イミングセット2)の2種類を有する画像形成装置に関 する例であるが、例えば、高速用、中速用、低速用等の 3種類以上のタイミング情報を備えた場合にも本発明を 適用することができる。この場合、受信バッファの空き プロックが十分な場合には、高速用のタイミング情報に 30 基づいてデータ転送を制御し、以下、空きブロックが不 足したら順次中速用、低速用のタイミング情報に基づい てデータ転送を制御すれば良い。

【0088】また、上記の実施の形態は、受信データを DMAコントローラにより受信バッファに格納する例で あるが、本発明は、例えば、制御部(CPU)によりこ の機能を代用する場合にも適用可能であることは言うま でもない。この場合、セントロニクス・インターフェー ス・コントローラより受信バッファに受信データを転送 するタスクを設けて上記の実施の形態に準じて並列処理 40 を行うことが望ましい。

【0089】また、上記の実施の形態は、ブロック単位 で受信パッファを管理する例であるが、本発明は、かか るプロック構成の受信バッファ以外にも適用可能である ことは言うまでもない。

【0090】また、上記の実施の形態は、本発明をセン トロニクス・インターフェースを有する画像形成装置に 適用した例であるが、本発明は、装置の形態や通信方式 等を限定するものではなく、所定の時間を経過しても応 答がない場合に異常が発生したとみなして処理を中止す 5) により解析される。なお、このコマンドに相当する 50 る外部機器に接続して用いる電子装置一般に広く適用可 (10)

特開平9-212335

18

能である。

【0091】なお、本発明は、複数の機器(例えば、ホストコンピュータ、インタフェイス機器、リーダ、プリンタなど)から構成されるシステムに適用しても、一つの機器からなる装置(例えば、複写機、ファクシミリ装置など)に適用してもよい。また、本発明の目的は、前述した実施形態の機能を実現するソフトウェアのプログラムコードを記録した記憶媒体を、システムあるいは装置に供給し、そのシステムあるいは装置のコンピュータ(またはCPUやMPU)が記憶媒体に格納されたプロ 10 グラムコードを読出し実行することによっても、達成されることは言うまでもない。

17

【0092】この場合、記憶媒体から読出されたプログラムコード自体が本発明の新規な機能を実現することになり、そのプログラムコードを記憶した記憶媒体は本発明を構成することになる。

【0098】プログラムコードを供給するための記憶媒体としては、例えば、フロッピディスク、ハードディスク、光ディスク、光磁気ディスク、CD-ROM、CD-R、磁気テープ、不揮発性のメモリカード、ROMな 20 どを用いることができる。

【0094】また、コンピュータが読出したプログラムコードを実行することにより、前述した実施形態の機能が実現されるだけでなく、そのプログラムコードの指示に基づき、コンピュータ上で稼働しているOS (オペレーティングシステム)などが実際の処理の一部または全部を行い、その処理によって前述した実施形態の機能が実現される場合も含まれることは言うまでもない。

【0095】さらに、記憶媒体から読出されたプログラムコードが、コンピュータに挿入された機能拡張ボード 30 やコンピュータに接続された機能拡張ユニットに備わるメモリに審込まれた後、そのプログラムコードの指示に基づき、その機能拡張ボードや機能拡張ユニットに備わるCPUなどが実際の処理の一部または全部を行い、その処理によって前述した実施形態の機能が実現される場合も含まれることは言うまでもない。

[0096]

【発明の効果】以上説明したように、本発明に拠れば、ある。 受信バッファの空き領域が少なくなったときに、データ 【図17】 がの転送速度を低速にし、データ転送を連続して停止する 40 す図である。 時間を短縮することにより、ホストコンピュータ等の外 【図18】 = 部機器のタイムアウトを軽減し、もってデータの転送効 おいて解析さ率を向上することができるという効果がある。

[0097]

【図面の簡単な説明】

【図1】本実施の形態に係る画像形成装置の構成例を示すブロック図である。

【図2】受信パッファ管理レジスタ群の構成例を模式的 に示す図である。

【図3】 ホストコンピュータと画像形成装置の間をセントロニクス・インターフェースを用いてデータ転送する一般的なタイミングを示す図である。

【図4】 タイミング・テーブルの構成例を模式的に示す 図である。

【図5】受信バッファ103の標成例を模式的に示す図である。

【図6】一般的な構成の受信バッファ内に受信データが存在する状態を模式的に示す図である。

【図7】受信バッファが満たされ、画像形成装置がホストコンピュータにデータの受信停止を通知する様子を模式的に示す図である。

【図8】セントロニクス・インターフェースのデータ転送速度の切替処理を模式的に示す図である。

【図9】本実施の形態における受信バッファの構成例を 模式的に示す図である。

【図10】画像形成装置におけるデータ解析量の時間変化の一例を模式的に示す図である。

【図11】 従来例におけるデータ転送量の時間変化

(a)と、空きブロック数の時間変化(b)を示す図で ある。

【図12】本実施の形態におけるデータ転送量の時間変化(a)と、空きブロック数の時間変化(b)を示す図である。

【図13】制御部110のメモリ110aに格納された 例御プログラムによる処理の流れを示す図である。

【図14】ステップS1306において起動されるデー 夕受信タスクにおける処理例を示すフローチャートであ る。

【図15】ステップS1403の1ブロック受信処理の「一例を示すフローチャートである。

【図16】ステップS1307において起動されるコマンド解析タスクにおける処理例を示すフローチャートである。

【図17】タイミング設定コマンドの一例を模式的に示す図である。

【図18】コマンド解析処理 (ステップS1605) において解析されたコマンドがタイミング設定コマンドである場合に実行されるタイミング設定タスクの一例を示すフローチャートである。

(11)

特開平9-212335

[図1]





タイミングテーブル

(12)







(13)







[図17]



(14)







(15)



